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Кратко о Postgres 13 


Сжатие (дедупликация) В-Тее. 


Инкрементальная сортировка: sorted(k1,k2) > sorted(k1,k2,k3) 


РГ /РО5ОГ не ходит в планировщик за простыми операторами 


Вычисление immutable функций на этапе планирования. 


Ускорение TRUNCATE (один скан 5Пагеа. Би егв вместо трех). 


Частичная декомпрессия ТОАЅТ. 


Вакуум индексов параллельно. 


Автовакуум при вставке (visibility тар для аррепа-опіу таблиц) 
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Повышение масштабируемости по 
коннектам 


Before & After Throughput Comparison (read-only pgbench workload) 
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Облегчение GetSnapshotData() 


Andres Freund: 
Analyzing the Limits of Connection Scalability in Postgres 
Improving Postgres Connection Scalability: Snapshots 
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Восходящее удаление 


(Bottom-up deletion) 


Прежде чем делать $рШ индексной страницы В-Тгее при 
UPDATE, не меняющем ключ индекса, попытаться 
зачистить старые версии на ней. 


Важная оптимизация при большом количестве ОРОАТЕ. 
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Асинхронный АРРЕМО 


Секционирование + FDW = Шардинг? 
SELECT # FROM partitioned Cable; 


Append 


-> Async Foreign Scan on partitioni1 
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Покрывающие индексы SP-GIST 


CREATE TABLE t (р point, z text); 


CREATE INDEX i USING spgist ON (p)INCLUDE (z); 


EXPLAIN SELECT * FROM t 
WHERE p <@ box(point(5,5),point(6,6)); 


Index Only Scan using i on t 


Indèx Cond: (р <0 (00); (579) "I1b03) 
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VACUUM 


* Параметры по умолчанию: 
vacuum cost раде miss = 10-2 #диски стали быстрее 


e Умеет выполняться параллельно с СВЕАТЕ ТМОЕХ | ВЕТМОЕХ 
CONCURRENTLY 


e Умеет не заходить в индексы, если сканирование таблицы нашло 
мало bloat'a. 


° VACUUM (РКОСЕ5Ѕ5 ТОАЗТ OFF) 
Ё Воркер ацюуасиит падает вслед за постмастером. 
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Реплики и репликация (1) 


Изменилась реакция реплики на изменение 
критических параметров 


е max connections 

° max prepared transactions 
е пах locks рег transaction 
2 max wal senders 

е пах worker processes 


Вместо остановки всей реплики теперь — остановка репликации с 
предупреждением. 
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Реплики и репликация (2) 


e Изменение restore command не требует перезапуска. 


е Для ра rewind можно использовать реплику в качестве 
соцгсе. 


e Логическая репликация: 
Передача больших транзакций постепенно. 
CREATE PUBLICATION .. WITH (streaming = оп) 


e Логическая репликация в двоичном формате (так быстрее) 
CREATE | ALTER SUBSCRIPTION .. WITH (binary = оп) 
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SET compute ачегу 14 = "оп!; 
Заполняется поле ра _ stat activity.query іа 
чем же, чем ра stat зѕзіаёсетепі . диегуіа 


e Новое представление: 


ра за зЕафетмепе$ 1пЕо ( 
Яеа11ос bigint, -- сколько раз переполнялось 
stats reset timestamptz -- когда сбрасывали 


PROFESSIONAL 


10 Розфагез н.) уон 


p9g-stat_statements 


e Различие верхнеуровневых и вложенных запросов. 
SEI pg stat зсасешепшевастаск = ал” 


SELECT toplevel, query 
FROM pg stat statements 


e Подсчет обработанных строк в поле rows для CREATE 
TABLE AS, SELECT INTO, CREATE MATERIALIZED 
VIEW, FETCH (раньше не считалось) 
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Новое представление ра. Та! ма! 


SET track иа! іо timing = "оп"; 
SELECT * FROM ра за wal; 
wal records | 21049276 
ма1 fpi | 79 full pageimages | Есть B pg-stat_statements 
wal bytes | 1242346187 
wal buffers fuir | 129335 раз 
wal write | 129555 pas 
wal sync | 239 pas 
wal write time | [337.535 ja 
wal sync time | 409.48 ~ 
| 


2021-05-14 17:04:36.006022+03 « —— 
12 Роѕўдгеѕ SELECT pg stat reset shared ('ма1') — рана 
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РезиПСаспе 


Новьи узел плана запроса. Кеширует результат 


внутреннего цикла в Nested | оор. 
SET enable_resultcache = ОМ; 


EXPLAIN (costs off) 
SELECT name FROM customer 
JOIN issue ON issue.customer = customer.id; 


Nested Loop 
-> Seq Scan on issue 
-> Result Cache 
Cache Key: issue.customer 
-> Тпдех 5сап using cüstomer іа idx оп customer 
13 Posğgres Index Cond: (іа = issue.customer) (ана 


Перестройка индекса в другой tablespace 


ВЕТМОЕХ (TABLESPACE space Го move) 
TABLE CONCURRENTLY tablename; 


Новый индекс создается в указанном tablespace. 
Нужно, когда кончается место. Альтернативы: 
ALTER INDEX .. SET TABLESPACE ... с 
ALTER TABLE .. SET TABLESPACE ... 
Расширение рд_зчдцееле  OveeREc 
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Конвейерный (pipeline) режим в (бра 


+ помогает, если: 


Много коротких 
команд, большие 
задержки в сети. 


Ждем поддержки 
в библиотеках 
более высокого 
уровня. 
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FDW 


e Новые параметры postgres_fdw: 


CREATE SERVER .. FOREIGN DATA WRAPPER postgres fdw 
OPTIONS (. Кеер connections 'off', 
batch size '100'); 


e Автоматический реконнект к удаленному серверу (не в 
транзакции) 
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Преаллокация shm для 
исполнения запросов 


e GUC 


min dynamic shared memory 
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параллельного 


5реед-ир compared {о serial hash join 
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Simple parallel hash join speed-up due to hash chunk size 
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Статистика 


e Статистика по выражениям на таблицах: 
CREATE STATISTICS 5 
ON some func(r.field1, const1) FROM table r; 


e Расширенная статистика лучше используется в OR-ax 
• В пустой таблице О записей 
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CONCURRENTLY... 


° ALTER TABLE .. DETACH PARTITION .. CONCURRENTLY; 


старые транзакции завершаются, видя эту секцию; 
новые уже не видят её, но работают. 


e Можно одновременно выполнять 
CREATE INDEX CONCURRENTLY или ВЕТМОЕХ 
CONCURRENTLY по нескольким различным таблицам. 
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Разное (1) 


е Выбор метода компрессии для TOAST (ра , [24 ) 
„/ИсопЕтаике -и1 Е Н-1х4 
SET default ЕоазЕ сотргеѕѕіоп = "124"; 
ALTER TABLE tab ALTER data SET COMPRESSION 124; 


е TRUNCATE удаленную секцию таблицы (T. е. удаленную таблицу) 
° БЕТ 191е ѕеѕѕіоп _ timeout = '1000ms'; 


e Ускорение зачистки shared buffers при TRUNCATE, DROP TABLE ИТП 
стараемся обходиться без полного перебора 


• пом () кешируется в рамках транзакции. 
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Разное (2) 


e Использование атрибута компилятора cold в ветках с 
обработкой ошибок. 

e Инкрементальная сортировка применяется для оконных 
функций 

e Ускорение построения GIST индекса с помощью 
пространственного упорядочивания. 

e ВЕМОЕХ применим к секционированным таблицам. 

e btree_gist стал РАКАШ ЕГ ЗАЕЕ 

e Parallel sequence scan работает пачками блоков, а не по 
одному. 
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Что читать 


На Хабре: 


и. Левшин 
е. Много ли нового в Чёртовой Дюжине? 


П. Лузанов 


е PostgreSQL 14: Часть 1 или «июльский разогрев» (Коммитфест 2020-07) 

е PostgreSQL 14: Часть 2 или «в тени тринадцатой» (Коммитфест 2020-09) 

e PostgreSQL 14: Часть З или «ноябрьское затишье» (Коммитфест 2020-11) 

e PostgreSQL 14: Часть 4 или «январское наступление» (Коммитфест 2021-01) 
е PostgreSQL 14: Часть 5 или «весенние заморозки» (Коммитфест 2021-03) 
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Спасибо за внимание! 


PGConf.Russia 
20 сентября 2021 г 
Следите за анонсами 
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